S.ELYAHYAOUI, PL/SQL 


G. Les enregistrements fie type RECORD) 


Définition : record 


Un RECORD ou enregistrement est une structure de données (similaire au type struct en 
langage C) qui peut contenir des valeurs de types différents (NUMBER, DATE, VARCHAR2, 

• • • | • 

Il existe 3 types d'enregistrements : 

■ Les enregistrements basés sur la structure d’une table 

■ Les enregistrements basés sur la structure d’un curseur 

■ Les enregistrements dont la structure est définie par le programmeur 


Les enregistrements basés sur la structure d'une table 


Syntaxe de déclaration (bloc déclaré): 

nom_record "nom_table"%ROWTYPE; 

Syntaxe d'initialisation : 


SELECT *Cinto nom 
FROM "nom^taBlë " 
WHERE condition; 


Syntaxe d’utilisation : 

nom record.nom colonne 



La requête de sélection doit 
obligatoirement retourner une seule ligne 


Exemple 


1. On se propose d’abord d’exécuter la requête (create table) de création de la 
table « .produit » ayant la structure suivante : 


Marne 

Type 

Length 

Scale 

Allow Nul 

id 

NUMBER 

3 

0 

□ Pi 

désignation 

VARCHAR2 

lüû 

0 

□ 

qteStock 

NUMBER 

2 

0 

□ 

prixUnit 

NUMBER 

6 

2 

□ 

2 . La table sera ensuite remplie des données suivantes (insert 

into) : 


id 

désignation 

qteStock 

prixUnit 



556 D. DUR Ext. Verbatim VRB3360V2 5ÜÜGB 


11 990,95 


555 Clef USB HP10VQ2-16GB 


2 

220 


3 . On utilise la structure de cette table pour créer et utiliser un enregistrement, qui va 
contenir les informations du produit ‘556’. Afficher ensuite ces informations. 

DECLARE 

produit_rec "_jproduit"%ROWTYPE; 

BEGIN 

SELECT * into produit_rec FROM "_produit" WHERE id = 556; 

dbms_output .put_line ( ’ ID produit: ’ || produit_rec . id) ; 

dbms_output . put_line ( ’ Désignation : ’ | | produi t_rec . désignation) ; 

dbms_output . put_line ( ’ Qté stock : ’ | | produi t_rec . qteStock) ; 

dbms_output .put_line ( ’ Prix unitaire: ’ || produi t_rec.prixünit) ; 

END; 
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Message 


DBMS Output 


ID produit: 556 

Désignation; D. DUR Ext. Verbatim VRB3360V2 5ÜÛGB 

Qté stock: 11 

Prix unitaire: 990.95 


A 


A IMPORTANT 


Un enregistrement ne peut contenir qu’une seule ligne de la table, donc la clause where 
est obligatoire si la table contient plusieurs lignes, et il faut que la requête select 
retourne une seule ligne. 

Si la table ne contient qu'une seule ligne, la clause where n' est pas obligatoire. 


Les enregistrements basés sur la structure d’un curseur 


Syntaxe de déclaration (bloc déclaré) : 
/* déclaration du curseur */ 


/* déclaration du RECORD */ 

nom_record "nom_curseur "%ROWTYPE; 

Syntaxe d’utilisation : 

/* ouverture du curseur */ 


nom_record. "nom_colonne " 

(Les notions de curseur, et curseur avec enregistrement seront revues en détail dans les 
prochains chapitres) 


Les enregistrements basés sur une structure définie par le programmeur 


Syntaxe de déclaration (bloc déclaré) : 


/* définition du RECORD */ 

TYPE nom_record IS RECORD ( 

Attribut_l TYPE_DE_DONNEES [NOT NULL] 
Attribut 2 TYPE DE DONNEES [NOT NULL] 



Optionnel, mais 

Optionnel 

obligatoire si not null 


[ := VALEUR], 
[ := VALEUR], 


Attribut N TYPE DE DONNEES [NOT NULL] [ := VALEUR] 


); 


/* déclaration d'un RECORD */ 

nom variable nom record; 


Syntaxe d’utilisation : 

nom variable, "nom attribut" 


Exemple 1 


On se propose de refaire l’exemple precedent, sans utiliser la table « _produit » comme 
structure de base pour la création du record. 


DECLARE 

/* définition du type RECORD nommé 
TYPE produc t IS RECORD ( 

id NUMBER NOT NULL := 1, 
désignation VARCHAR2(50) , 


"product" */ 
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qteStock NUMBER, 
prixUnit NUMBER (6, 2) 


) ; 


BEGIN 


/* déclaration d’un produc t nommé produit_l */ 
produit_l product; 

/* initialisation des attributs du product produit_l */ 
produit_l . désignation := ’ PC Portable’; 
produit_l . qteStock := 5; 
produit_l .prixUnit := 7000; 

dbms_output .put_line ( ’ ID produit: ’ || produit_l . id) ; 

dbms_output . put_line ( ’ Désignation : ’ | | produi t_l . désignation) ; 

dbms_output . put_line ( ’ Qté stock : ’ | | produi t_l . qteStock) ; 

dbms output.put line (’ Prix unitaire: ’ || produit 1. prixUnit); 


END; 


Message 


DBMS Output 


ID produit: 1 
Désignation: PC Portable 
Qté stock: 5 
Prix unitaire: 7ÛÜÜ 


Exemple 2 


On se propose encore de refaire l’exemple précédent, sans utiliser la table « .produit » 
comme structure de base, mais en utilisant ses types de colonnes pour typer les attributs 
du record ( % type ). 


"product” */ 


DECLARE 

/* définition du type RECORD nommé : 

TYPE product IS RECORD ( 

id ’’_jproduit" .id%TYPE NOT NULL := 1 , 
désignation ’’__produit” . designation%TYPE , 
qteStock "^produit” . qteStock%TYPE , 
prixUnit "^produit” .prixUnit%TYPE 

) ; 

/* déclaration d’un product nommé produit__l */ 
produit_l product; 


BEGIN 


/* initialisation des attributs du product produit_l */ 
produit_l . désignation := ’ PC Portable'; 
produit_l . qteStock := 5; 
produit_l .prixUnit := 7000; 
dbms_output . put_line ( ' ID produit : 
dbms_output . put_line ( ' Désignation : 
dbms_output . put_line ( ' Qté stock : ' 


| | produit_l . id) ; 

' | | produit_l . désignation) ; 

| | produit_l . qteStock) ; 


dbms_output .put_line ( ' Prix unitaire: ' || produit_l .prixUnit); 


END; 
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Etude de cas 


Records - table a commande » 


1 . Créer la table «_commande » ayant la structure suivante : 


Na m e 

Type 

Length 

Scdle 

Allow Nul! 

NU M COM 

NUMBER 

4 

0 

□ J&l 

DATE COM 

DATE 

7 

0 

□ 


2. La table sera ensuite remplie des données suivantes : 


N U MCO M DATE COM 

11 2010-02-19 

12 2010 - 02-22 
14 2010-03-01 
16 2012-04-10 

3. Utiliser un enregistrement pour afficher les données de la dernière ligne de la table. 
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